[id].vue 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <!-- Page de détails d'un sous-domaine -->
  2. <template>
  3. <div>
  4. <h3 class="my-8">{{ $t('activate_a_subdomain') }}</h3>
  5. <v-card class="parameters-page-card">
  6. <UiLoadingPanel v-if="pending" />
  7. <div v-else-if="subdomain !== null">
  8. <div>{{ $t('youRegisteredTheFollowingSubdomain') }} :</div>
  9. <div class="pa-8">
  10. <b>{{ subdomain.subdomain }}</b>
  11. <span class="text-on-neutral">.opentalent.fr</span>
  12. </div>
  13. <div>
  14. <div v-if="subdomain.active">
  15. <v-icon class="text-success icon small mr-2">
  16. fa-solid fa-check
  17. </v-icon>
  18. {{ $t('subdomainIsCurrentlyActive') }}
  19. </div>
  20. <div v-else>{{ $t('doYouWantToActivateThisSubdomain') }} ?</div>
  21. </div>
  22. <div class="mt-6 d-flex flex-row">
  23. <v-btn class="mr-12" @click="quit">
  24. {{ $t('back') }}
  25. </v-btn>
  26. <div v-if="!subdomain.active">
  27. <v-btn color="primary" @click="activateAndQuit">
  28. {{ $t('activate') }}
  29. </v-btn>
  30. </div>
  31. </div>
  32. </div>
  33. </v-card>
  34. </div>
  35. </template>
  36. <script setup lang="ts">
  37. import type { Ref } from 'vue'
  38. import Subdomain from '~/models/Organization/Subdomain'
  39. import { useEntityFetch } from '~/composables/data/useEntityFetch'
  40. import { useEntityManager } from '~/composables/data/useEntityManager'
  41. import { usePageStore } from '~/stores/page'
  42. import { TYPE_ALERT } from '~/types/enum/enums'
  43. import { useRefreshProfile } from '~/composables/data/useRefreshProfile'
  44. import { useRouteUtils } from '~/composables/utils/useRouteUtils'
  45. const { em } = useEntityManager()
  46. const { fetch } = useEntityFetch()
  47. const router = useRouter()
  48. const { refreshProfile } = useRefreshProfile()
  49. const { getIdFromRoute } = useRouteUtils()
  50. const id = getIdFromRoute()
  51. const { data: subdomain, pending } = fetch(Subdomain, id)
  52. const activationPending: Ref<boolean> = ref(false)
  53. const pageStore = usePageStore()
  54. const activateAndQuit = async () => {
  55. activationPending.value = true
  56. pageStore.loading = true
  57. await em.patch(Subdomain, id, { active: true })
  58. await refreshProfile()
  59. usePageStore().addAlert(TYPE_ALERT.SUCCESS, [
  60. 'subdomain_activated_and_available_in_a_few_minutes',
  61. ])
  62. quit()
  63. }
  64. const quit = () => {
  65. router.push('/parameters/website')
  66. activationPending.value = false
  67. pageStore.loading = false
  68. }
  69. </script>